package org.jeecg.modules.wms.entity;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
import org.jeecgframework.poi.excel.annotation.Excel;
import org.springframework.format.annotation.DateTimeFormat;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 物料组成明细
 */
@Data
@TableName("wms_material_detail")
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@ApiModel(value = "wms_material_detail对象", description = "物料组成明细")
public class WmsMaterialDetail implements Serializable {

    private static final long serialVersionUID = 1L;

    /**
     * 明细ID
     */
    @TableId(type = IdType.ASSIGN_ID)
    @ApiModelProperty(value = "明细ID")
    private String id;

    /**
     * 物料ID（主表ID）
     */
    @ApiModelProperty(value = "物料ID（主表ID）")
    private String materialId;

    /**
     * 组成物料类型（1:型材,2:配件,3:辅件,4:其他,5:余料,6:半料）
     */
    @Excel(name = "组成物料类型", width = 15, dicCode = "material_type")
    @ApiModelProperty(value = "组成物料类型（1:型材,2:配件,3:辅件,4:其他,5:余料,6:半料）")
    private String materialType;

    /**
     * 组成物料编号
     */
    @Excel(name = "组成物料编号", width = 15)
    @ApiModelProperty(value = "组成物料编号")
    private String materialCode;

    /**
     * 组成物料名称
     */
    @Excel(name = "组成物料名称", width = 20)
    @ApiModelProperty(value = "组成物料名称")
    private String materialName;

    /**
     * 规格型号
     */
    @Excel(name = "规格型号", width = 15)
    @ApiModelProperty(value = "规格型号")
    private String specification;

    /**
     * 数量
     */
    @Excel(name = "数量", width = 15)
    @ApiModelProperty(value = "数量")
    private BigDecimal quantity;

    /**
     * 单位
     */
    @Excel(name = "单位", width = 10)
    @ApiModelProperty(value = "单位")
    private String unit;

    /**
     * 备注
     */
    @Excel(name = "备注", width = 30)
    @ApiModelProperty(value = "备注")
    private String remark;

    /**
     * 创建人
     */
    @ApiModelProperty(value = "创建人")
    private String createBy;

    /**
     * 创建时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "创建时间")
    private Date createTime;

    /**
     * 更新人
     */
    @ApiModelProperty(value = "更新人")
    private String updateBy;

    /**
     * 更新时间
     */
    @JsonFormat(timezone = "GMT+8", pattern = "yyyy-MM-dd HH:mm:ss")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @ApiModelProperty(value = "更新时间")
    private Date updateTime;

    /**
     * 租户ID
     */
    @ApiModelProperty(value = "租户ID")
    private String tenantId;
    
    /**
     * 来源物料颜色（关联查询）
     */
    @TableField(exist = false)
    @ApiModelProperty(value = "来源物料颜色")
    private String color;
    
    /**
     * 来源物料品牌（关联查询）
     */
    @TableField(exist = false)
    @ApiModelProperty(value = "来源物料品牌")
    private String brand;
    
    /**
     * 来源物料长度（关联查询）
     */
    @TableField(exist = false)
    @ApiModelProperty(value = "来源物料长度")
    private BigDecimal length;
    
    /**
     * 来源物料宽度（关联查询）
     */
    @TableField(exist = false)
    @ApiModelProperty(value = "来源物料宽度")
    private BigDecimal width;
    
    /**
     * 来源物料高度（关联查询）
     */
    @TableField(exist = false)
    @ApiModelProperty(value = "来源物料高度")
    private BigDecimal height;
} 